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(57) Abstract 

Service resource items (49) for use in call senip 
in a telephone system are held on servers (58) that are 
connected to a computer network wtiich is logically 
distinct from the telephone system infiastnicnirc; this 
computer network may, for example, make use of the 
Internet. Each service resource item (49) is locatable on 
the network at a conesponding URI and is associated 
widi a particular ceiephorie nuaciber. A mapping is 
provided between telephone mn^en and the URIs of 
associated service resource hens. When it is desired 
to access a service resource item (49) associated with 
a particular telephone number, this mapping is used to 
retrieve the corresponding URI (step 55) which is then 
used to access the desired service resource item (56. 57, 
59). 
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METHOD OF ACCESSING SERVICE RESOURCE ITEMS THAT ARE FOR 
USE IN A TELECOMMUNICATIONS SYSTEM 



FiaM nf the Invention 
The present invention relates to a method of accessing se^^•ice resource items that are 
intended to be used in setting up bearer channels through a switched 
telecoirur.unications system. 

10 

As used herein, the term "switched telecommunication system" means a s>'sxem 
comprisine a bearer nerwork with switches for setting up a bearer channel through the 
network. The term "switched telecommunication system" -Is to be taken to include not 
only the existing public and private telephone systems (whether using analogue phones 
15 or ISDN-based), but also broadband (ATM) and other switch-based bearer networks 
that are currently being implemented or may emerge in the fumre. For convenience, 
the term 'switched telecommunication system" is sometimes shortened herem to 
telecommunication system. 

20 Reference to a "call" in the context of a swuched telecoir-n:umcation s>-s'^m is to be 
understood as meaning a communication through a bearer channel set up across the 
bearer network. whUst references to call semp. maintena^ and takedown are to be 
taken to mean the processes of setting up. maintaining and taking down a bearer 
channel through the bearer network. Terms such as "call processing" and "call 

25 handling" are to be similarly interpreted. 

The term -communication system" when used here:n should be understood as havmg 
a broader meamng than switched telecommunication s>-sten^.. and is intended to tncluoe 
datagram-based communication systems where each data packet ts independently routec 
30 throueh a bearer network without following a predetermined bearer channel. 
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Background of the Invention 

Teleconimurucation companies running PSTNs (Public Switched Telephone Networks) 
and PLMNs (Public Land Mobile Networks) are in the business of providing 
conimunication services and in doing so are providing increasing built-in intelligence 

5 in the form of "IN services" such as 800 number services and call forwarding. In 
contrast, the World Wide Web (WWW), which has seen explosive growth in recent 
times, is an example of an Internet-based global network providing complex 
information ser\'ices. These two worlds, that of the large communications utilities and 
that of the highly dynamic, pioneer-spirit \V^^^ information culaire, are uneasy 

10 companions and each plans to encroach on the domain previously occupied by the 
others; thus telephony services will be offered over the WW\S- and information s^r^iccs 
over the public communication infrastructure. 

The present invention proposes technologies for a more synergetic relationship between 
15 these two worlds than is currently envisaged and in order to place the present invention 
in context, a review will first be given of each of these two worlds. 



Telephone Networks with IN Se^^'ices 

20 

The Basic PSTN, The basic service provided by a PSTN (Public Switched Telephone 
Network) is the interconnection of two telephones (that is, sening up a bearer channel 
between the telephones) according to a called-party telephone number input at the 
calling-party telephone. Figure 1 is a simplified representation of a PSTN providing 

25 such a service. In particular, customer premises equipment, CPE. 10 (such as standard 
analogue telephones, but also more recently ISDN terminals) are connected through an 
access network 11 to switching points, SPs 12. The SPs 12 form nodes in an int^ 
exchange network 13 made up of imerconnecting trunks 14 and SPs that are controlled 
by control entities 15 in the SPs. The control effected by the control entities 15 is 

30 determined by signalling inputs received from the CPEs and other SPs, and involves 
call setup, maintenance and clearance to provide the desired bearer channel between 
calling CPE and called CPE. Conceptually, the PSTN may be thought of as a bearer 
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network and a conirol (signalling) network, the function of the laner being to effect call 
control through the bearer network, namely the control of semp. maintenance and take 
down of bearer channels through the bearer network; in practice, the bearer and 
signalling networks may use the same physical circuits and even the same logical 
5 channels. 



Thus, where the CPE is a traditional dumb telephone, control signalling between the 
CPE and its local SP is in-band signalling, that is. the signalling is carried on the same 
channel as used for voice; this signalling is interpreted and convened at the SPs 12 into 
10 signalling between SPs that uses a dedicated common-channel signalling necv/ork 16 
(implemented nowadays using the SS7 protocol suite). \\^ere the CPE is an ISDN' 
terminal, signalling is carried in a separate channel directly from the CPE on an end- 
to-end. Modem SPs use the ISUP (ISDN User Part) SS7 protocol for inter-exchange 
call control signalling whether the CPE is a standard telephone or an ISDN terminal. 

15 

Telephone Numbering Flans - As ceruin aspects of the present invention are 
influenced by the structuring of telephone numbers, a brief description will now be 
given of the structuring of such numbers. Telephone numbers form an international, 
hierarchical addressing scheme based on groups of decirr.al digits. The top level of the 

20 hierarchy is administered by the ITU-T, which has allocated single-digit numeric codes 
to the major geographic zones (for example "1" for Nonh .-Vmerica, °2" for Africa. 
"3" for Europe. "4" for Europe. "5" for South America and Cuba, etc.). Within each 
rone countries are assigned 2 or 3 digit codes, so that within zone 3 France is "33", 
and within zone 4 the UK is "44". Adminisu^tion of the numbering plan within a 

25 country is delegated to a national body, such as the Office of Telecommunications 
("Oftel") in the UK. The following further description is based on the UK numbering 
plan, but the scheme described will be recognised as having widespread applicability. 

In the UK all national numbers are prefixed by a code from 01 to 09 (the '0' preilx is 
30 dropped in international dialling). The currently assigned codes are "01" for 
Geographic Area Codes. "02" for Additional Geographic Area Codes. "04" for Mobile 
Services, "07" for Personal Numbers, and "08" for Special Service (freephone. 
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information). Normal wireline PSTN subscriber telephone numbers are aJlocaied from 
the Geographic Area Code codes, and currently only codes prefixed by 01 are 
allocated. Geographic area codes are presently 3 or 4 digits (excluding the leading '0') 
and there are currently 638 geographic areas each with its own code. A full r^iional 
5 UK dialled number takes two forms: 

0 171 634 8700 

area code local number (7 digit) 

0 1447 456 987 

area code local number (6 digit) 

10 The fu^t case has the *0' prefix, a 3 digit area code and a 7 digi: local numfc-er, and 
the second case has the *0' prefix, a 4 digit area code, and a 6 digit local njmber. 
Further interpretation of the local number will take place within the area exchange, as 
even a 6 digit address space is too large for a single switch, and for a typical local area 
several switches may be needed to host the required number of subscriber lines. This 

15 interpretation is opaque and is a matter for the area serv'ice provider. 



In the current PSTN the inherently hierarchical and geographic interpreiauon of 
telephone numbers is mirrored by the physical architecrure of the network. A :e>phone 
number is structured in a way th^t niakes it easy to rouce a call through the nerwork. 

20 At each step, the prefix of the number provides information about the current routing 
step, and the suffix (perhaps opaquely) provides information about subsequen: routing 
steps; as long as a switch kiK)ws how lo parse a prefix and carry out a routing step, it 
does not need to understarxl the content of the suffLX, which is left for subsequent 
routing steps. For this reason the international and national switching fabric is also 

25 organised hierarchically. 

Intelligent Networks. Renaming now to a consideration of the current te":ep'r-one 
network infrastruture, in addition to basic call handhng. an SP may also ser. e to 
provide what are called IN (Intelliger^ Network) ser^Mces; in this case the SP is :ermed 
30 a service switching point, SSP. An SSP 25 is arranged to suspend call processing at 
derlned points-in-call upon particular criteria being me:, and to delegate the 
continuation of call processing to a ser\'ice control subsystem providing a ser-ice 
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control function (SCF) either in the form of a service control point. SCP 17 (see Figure 
2) or an Adjunct 18. The Adjunct 18 is directly associated with an SSP 25 whilst the 
SCP 17 and SSP 25 communicate with each other via an extended common channel 
signalling (CCS) network 16 that may include signal transfer points (STP) 19. The SCP 
5 17 may be associated with more than one SSP 25. Both the SCP 17 and Adjunct 18 
provide a service logic execution environment (SLEE) 20 in which instajjces of one or 
more service logic programs (SLP) 21 can execute. The SLEE 20 and SLP 21 together 
provide service control functionality for providing services to the SSP 25. 

10 Service logic running in an SCP or Adjunct will generally make use of subscriber 
information stored in a service data function (SDF) 22 that may be integral with the 
SCP/Adjunct or partially or wholly separate therefrom. The service data function 
(SDF). like the service control function (SCF) forms part of the service control 
subsystem of the PSTN. It may be noted that some or all of the service control function 

15 may be built into the PSTN switches themselves. 

In addition to the SCP 17 and Adjunct 18, the Figure 2 network includes an intelligent 
peripheral (IP) 23. The IP 23 provides resources to che SSP 25 such as voice 
announcements and DTMF digit collection capabilities. Tl.e network will also include 
20 an operation system (not shown) that has a general view of the network and its services 
and performs functions such as network monitoring and control. 

In operation, when the SSP 25 receives a call, it examines internal trigger conditions 
and, possibly, user information (eg dialled digits) to ascertain if the call requires a 

25 service to be provided by the service control subsystem 17. 18; the checking of trigger 
conditions may be carried out at several different points in call processmg. Where the 
SSP 25 determines that a service is required it messages the ser\'ice control subsystem 
(either SCP 17 or Adjunct 18) requesting the desired sen-ice and sending it a logic 
representation of the call in terms of its connectivity and call processing sutus. The 

30 service control subsystem then provides the requested ser.'ice and this may involve 
either a single interaction between the SSP and service conu-ol subsystem or a session 
of imeractions. A typical service is call forwarding which is a called-pany ser%'ice 
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giving expression to an end-user requirement as simple as "if you call me on number 
X and it rings ten times, tr>' callLng number YV In this case, it is the SSP local to the 
called end-user that triggers its associated SCP (or Adjunct) to provide this service; it 
will, of course, be appreciated that the SSP must be primed to know that the service 
5 is to be provided for a called number X. 

The above-described model for the provision of IN services in a PSTN can also be 
mapped onto PUvWs (Public Land Mobile Networks) such as GSM and other mobile 
networks. Control signalling in the case of a mobile subscriber is more complex 

10 because in addition to all the usual signalling requirements, there is also a need to 
establish where a call to a mobile subscriber should be routed; however, this is not a 
very different problem from a number of called-parry IN ser\'ices in the PSTN. Thus 
in GSM, the service data function (SDF) is largely located in a system named a Home 
Location Register (HLR) and the service control function in a system named a Visitor 

15 Location Register (VLR) that is generally associated on a one-to-one basis with each 
SSP (which in GSM terminology is called a Mobile Switching Centre, MSG). 



Because subscribers are mobile, the subscriber profile is transported from the HLR to 
whichever VLR happens to be functionally closest to be mobile subscriber, and from 
20 there the VLR operates the (fixed) service using the subscriber profile and interacts 
with the SSP. The HLR and VLR thus constitute a service control subsystem sLmilar 
to an SCP or Adjunct with their associated databases. 

It is, of course, also possible to provide IN ser\ices in private telephone systems and. 
25 in this case, the service control function and service data function are generally either 
integrated into a PABX (Private Automatic Branch Exchange) or provided by a local 
computer. The service control subsystem, whilst present, may thus not be a physically 
distinct from the PABX. 

30 The above-described general architectural framework for providing IN services has 
both strengths and flaws. Its main strength is that it works and many services have 
been successfully deployed, such as 800 number services, credit card calling. 
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voiccmail. and various call wailing and redirection ser^'ices. However, despite years 
of standardisation, services are still implemented one-at-a-time on proprietai^' platforms 
and do not scale well. The approach has been based on large, fault-tolerant systems 
which provide services for hundreds of thousands or even millions of subscribers and 
5 take years to deploy. Furthermore, since the networks used to support these services 
also constitute the basic telephone infrastructure, anything attached to these networks 
must be rigorously vetted. Additionally, each country and operator tends to have local 
variations of the so-called standards making it difficult to supply standard products and 
thereby braking the dynamics of competition. 

10 

The Worid Wide Web 

In contrast to the slow deliberate progress of the telephone infrastructure, the W^V^V 
has grown explosively from its inception in 1989 to become the primary electronic 
infonnation distribution service in terms of spread, availability and richness of 
15 information content. Anyone can, for a modest outlay, becom.e an information provider 
with a world-wide audience in a highly interconnected im'ormation architecmre. 

The WWW is a client-server application running over the Internet and vising a client- 
server protocol which mandates only the simplest of e.\:hanges between client and 
20 server. This protocol is HTTP (Hyper Text Transfer Protocol) which is optimised for 
use over TCP/IP networks such as the Internet; the HTTP protocol can, however, also 
be used over networks using different communication protocol stacks. 

Since the availabUity of literamre concerning the WWW has seen the same sort of 
25 growth as the WWW itself, a detailed description of the WWW, HTTP and the Internet 
will not be given herein. An outline description will, however, be given wiuh attention 
being paid to certain features of relevance to the present invention. 

The WWW uses the Internet for interconnectivit>-. Internet is a system that connects 
30 together networks on a worldwide basis. Internet is based on the TCP/IP protocol suite 
and provides connectivity to networks that also use TCP/IP. For an entity to have a 
presence on the Internet, it needs both access to a network connected to the Internet 
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and an IP address. IP addresses are hierarchically structured. Generally an entity will 
be identified at the user level by a name that can be resolved into the corresponding 
IP address by the Domain Name System (DNS) of the Internet, Because the DNS or 
adaptions of it are fundamental to at least certain embodiments of the invention 
5 described hereinafter, a description will next be given of the general form and 
operation of the DNS. 

The Domain Name System - The DNS is a global, distributed, database, and without 
its performance, resilience and scalability much of the Internet would not exist in its 
10 current form. The DNS, in response to a client request, serves to associate an Internet 
host domain name with one or more Registration Records (RR) of differing types, the 
most common being an address (A) record (such as 15.144.8.69) and mail exchanger 
(MX) records (used to identify a domain host configured to accept electronic mail for 
a domain). The RRs are distributed across DNS name servers world-wide, these 
15 servers cooperating to provide the domain name U"anslation service; no single DNS 
server contains more than a small part of the global database, but each server knows 
how to locate DNS ser\'ers which are "closer" to the data than it is. For present 
purposes, the main characteristics of the DNS of interest are: 

The host name space is organised as a tree-structured hierarchy of nodes with 
20 each host having a corresponding leaf node; each node has a label (except the 

root node) and each label begins with an alphabetic character and is followed 
by a sequence of alphabetic characters or digits. Tb& full, or "fully qualified" 
name of a host is the string of node labels, each separated by a from the 
corresponding leaf node to the root node of the hierarchy, this latter being 
25 represented by a terminating in the name. Thus a host machine "fred'' of 

Hewlett-Packard Laboratories in Bristol, England will have a fully qualified 
domain name of "fred.hpLhp.com. " (note that if a host name does not have a 
terminal it is interpreted relative to the current node of the naming 
hierarchy). 

30 — Each host has one or more associated Registration Records (RRs). 

There are a plurality of DNS servers each with responsibility for a subtree of 
the name space. A DNS ser\'er will hold RRs for all or pan of its subtree - in 
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the laner case it delegates respoasibility for the rerr^iTKler of uhe subiree to one 
or more further DNS servers. A DNS seiner knows the address of any server 
to which it has delegated responsibility aiKl also the address of the server which 
has given it the responsibility for the subtree it manages. The DNS servers thus 

5 point to each other in a stmcturing reflecting that of the naming hierarchy. 

-- An application wishing to make use of the DNS does so through ar associated 
-resolver" that knows the address of at least one DNS server, "^"aen a DNS 
server is asked by this resolver for an RR of a scecitled host, it wUl return 
either the requested RR or the address of a DNS se-.er closer :o che server 

10 holding the RR in terms of traversal of the nam^g ruerarchy. sffeci. the 

hierarchy of the servers is ascended until a serv er is reached ti-^: also has 
responsibility for the domain name to be resolved: --hereaner. the DNS ser\er 
hierarchy is descended down to the server holding ---e RR for the ccmam name 
to be resolved. 

15 The DNS uses a predetermined message format (ir. :2c:. it s the sair.e for query 

and response) and uses the IP protocols. 
These characteristics of the DNS may he considered as de:Vji:g 3 "DNS-r-Te- system 
always allowing for minor variations such as in label r-THzx. how the labels are 
combined (ordering, separators), the message formal -e-iii. evolu:ior_^ of the IP 

20 protocols etc. 

Due to the hierarchical naming structure, it is possible tc delega'^ respcasibility for 
administering domains (subtrees) of the name space recursively. Thus, the top-levei 
domains are administered by InterNic (these top-level domains include ±e familiar 
25 'com', 'edu-. 'org', 'inf. 'net*, 'mil' domains as well zs toc-level cocr-/ domains 
specified by standard tv/o-letter codes such as 'us', 'uk'. fr' etc.). .\t the next level, 
by way of e.xample Hewlett-Packard Company is respor_-:rle for aU na.-.- erKling m 

'hp.com' and British Universities are collectively respcr^.rie fc: ail r^-K ending 

'ac.uk'. Descending further, and again by way of exa-ple. admims:r-ion of the 
30 domain 'hpl.hp.com' is the responsibility of Hewler.-Packard Lab.c-:ones and 

administration of the subtree (domain) 'newcastle.ac.uK ih.e respor^iiriiitv' of th:e 

University of Newcastle-upon-Tyne. 
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Figure 3 illustrates the progress of an example quer\' made from within Hewleti- 
Packard Laboratories. The host domain name to be resolved is *xy-newcastle.ac.uk\ 
a hypothetical machine at the University of Newcastle, United Kingdom. The query 
is presented to the DNS server responsible for the "hpl.hp.com" subtree. This server 
does not hold the requested RR and so re^nds with the address of the "hp. com" DNS 
server; this server is then queried and responds with the address of the 'com* DNS 
server which in turn responds with the address of the * / (root) DNS server. The querv' 
then proceeds iteratively down the *uk' branch until the ^newcastle.ac.uk' server 
responds with the RR record for the name 'xy' in its subtree. 



10 



This looks extremely inefficient, but DNS ser\'ers are designed to build a dynamic 
cache, and are initialised with the addresses of several root servers, so in practice most 
of the iterative queries never take place. In this case the 'hpl.hp.com' DNS sender will 
know the addresses of several root servers, and will likely have the addresses of 'uk' 

15 and *ac.uk' servers in its cache. The fu^t query to the 'hpl.hp.com' server will remm 
the address of the *ac.uk' server. The second query to the 'ac.uk' server will remm 
the address of the *newcastle. ac.uk' server, ajKl the third query will remm the RR in 
question. Any future queries with a 'newcastle.ac.uk' prefix will go direct to the 
newcastle DNS ser/er as that address will be retained in the "hpl.hp.com" DNS server 

20 cache. In practice names within a local subtree are resoived in a single quer>\ and 
names outside the local subtree are resolved in two or three queries. 

Rather than a resolver being responsible for carrying out the series of query iterations 
required to resolve a domain name, the resolver may specify its first query to be 
25 recursive in which case the receiving DNS sender is responsible for resolving the querv' 
(if it cannot directly remm the requested RR, it will itself issue a recursive query lo 
a 'closer' DNS server, and so on). 

It should also be noted that in practice each DNS server will be replicated, that is. 
30 organised as a primary and one or more secondaries. A primary DNS nameserver 
initialises itself from a database maintained on a local tile system, while a seccndar\' 
initialises itself by transferring information from a primary. A subtree will normalh' 
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have one primary nameserver and anything up to ten secondaries - tJie limitation tends 
to be the time required by the secondaries to update their databases from the primary. 
The primary daubase is the master source of subtree information and is raainuined by 
the domain DNS administrator. The secondaries are not simply standby secondaries but 
5 each actively participates in the DNS with dependent servers that point to it rather than 
to the corresponding primary. 

DNS implementations, such as BIND, are widely available as a standard pan of most 
UNIX systems, and can claim to be among the most robust and widely used distributed 
10 applications in existence. 

Operation of the Referring now to Figure 4 of the accompanying drawings, 

access to the Internet 30 may be by direct connection to a network that is itself directly 
or indirectly connected to the Internet; such an arrangement is represented by terminal 
15 31 in Figure 4 (this terminal may. for example, be a Unix workstation or a PC). 
Having a connection to the Internet of this foma is known as having 'network access'. 
Any entity that has network access to the Internet may act as a server on the Internet 
provided it has sufficient associated functionality; in Figure 4. entity 32 with file store 
37 acts as a server. 

20 

Many users of the WWW do not have network access to the Internet but instead access 
the Internet via an Internet service provider. ISP, 33 that does have nerwork access. 
In this case, the user terminal 34 will generally communicate with the ISP 33 over the 
public telephone system using a modem and employing either SLIP (Serial Line 

25 Interface Protocol) or PPP (Point-to-Point Protocol). These protocols allow Internet 
packets to traverse ordinary telephone lines. Access to the Internet of this form is 
known as 'dialup IP" access. With this access method, the user terminal 34 is 
temporarily allocated an IP address during each user session: however, since this IP 
address may differ between sessions, it is not practical for the entiry 34 to act as a 

30 server. 
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A cornerstone of the WWW is its ability to address particular information resources 
by means of an Uniform Resource Identifier (URI) that will generally be either a 
Uniform Resource Locator (URL) that identifies a resource by location, or a Uniform 
Resource Name (URN) that can be resolved into an URL. By way of example, a full 
5 or "absolute" URL will comprise the following elements: 

scheme - this is the access scheme to be used to access the resource of 

interest; 

host - the Internet host domain name or IP address; 

port - the host pon for the (TCP) connection; 

10 abs-path - the absolute path of the resource on the host. 

In fact, the 'port' may be omitted in which case port 80 is assumed. 

Figure 5 of the accompanying drawings shows an example URL for the Hewlett- 
Packard products welcome page. In this case, the elements are: 
15 scheme - http 

host - w^ww. hp.com 

port - omitted (pon 80 assumed) 

abs-path - Products.html 

20 The HTTP protocol is based on a request/ response paradigm. Referring again to Figure 
4 of the drawings, given a panicular URI identifying a resource 30 to be accessed, a 
client establishes a connection with the server 31 corresponding to the ''host" element 
of the URI and sends a request to the server. This request includes a request method, 
and the 'Request- URI" (which is generally just the absolute path of the resource on the 

25 server as identified by the "abs-path" element of the URI); the request may include 
additional data elements. The server 31 then accesses the resource 36 (here held on 
storage 37) and responds and this response may include an entity of a tv^e identified 
by a MIME (Multipurpose Internet Mail Extensions) type also included in the response. 



30 



The two main request methods are: 

GET - This method results in 'Jie retrieval of whatever information (in the 
form of an entity) is identified by the Request-URI. It is imponant to 
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note thai if the Request-URI refers to a data -producing process, it is the 
produced data which is returned as the entity in the response and not the 
source text of the process. 
POST - This method is used to request that the destination server accept the 
5 entity enclosed in the request as a new subordinate of the resource 

identified by the Request-URI. The POST method can be used for 
annotation of existing resources, providing a message to a bulletin 
board, providing data to a data-handling process (for example, data 
produced as the result of submitting a form), and extending a database 
10 through an append operation. 

In summary, the GET method can be used to directly retrieve data, or to trigger any 
process that will remm an entity ( which may either be data or a simply an indication 
of the result of running the process). The POST method is used for registering data and 
specif>'ing this method is also effective to trigger a process in the ser\'er to handle the 
15 posted data appropriately. 

The passing of information to a process triggered to run on a server using either the 
GET or POST method is currently done according to an interface called the Common 
Gateway Interface (CGI). The receiving process is often written in a scripting language 
20 though this is not essential. Typically, the triggered server script is used for interfacing 
to a database to service a query included in a GET request. Another use. already 
referred to. is to append data associated with a POST request to a database. 

Other important factors in the success of the WWW is the use of the HyperText 
25 Markup Language (HTML) for representing the makeup of documents transferred over 
the WWW. and the availabUity of powerful graphical Web browsers, such as Netscape 
and Mosaic, for interpreting such documents in a client terminal to present them to a 
user. Basically, HTML is used to identify each part of a document, such as a title, or 
a graphic, and it is then up to the browser runmng in the client terminal to decide how 
30 to display each document part. However. HTML is more than this - it also enables a 
URI and a request method to be associated with any element of a document (such as 
a particular word or an image) so that when a user points to and clicks on that element. 
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the resource identified by the URI is accessed according to the scheme (protocol) and 
request method specified. This arrangement provides a hyperlink from one document 
to another. Using such hyperlinks, a user at a client terminal can skip effortlessly from 
one document downloaded from a server on one side of the world, to another docimient 
5 located on a server on the other side of the world. Since a document created by one 
author may include a hyperlink to a document created by another, an extremely 
powerful document cross-referring system results with no central bureaucratic control. 

Hyperlinks are not the only intelligence that can be built into an HTML document. 

10 Another powerful feature is the ability to fill in a downloaded "Form" document on 
screen and then activate a 'commit' graphical button in order to have the entered 
information passed to a resource (such as a database) designed to collect such 
information. This is achieved by associating the POST request method with the 
'commit' button together with the URI of the database resource; activating the 

15 ^commit' button results in the entered information being posted to the identified 
resource where it is appropriately handled. 

Another powerful possibilit>' is the association of program code (generally scripts to 
be interpreted) with particular documents elements, such as graphical buttons, this code 
20 being executed upon the button being activated. This opens up the possibilit\' of users 
downloading program code from a resource and then running the code. 

It will be appreciated by persons skilled in the art that HTML is only one of several 
currently available scripting languages delivering the functionality outlined above and 
25 it may be expected that any serious Web browser will have built-in support for multiple 
scripting languages! For example, Netscape 2.0 supports HTML 3,0, Java and 
LiveScript (the latter being Netscape proprietarv' scripting Language). 



30 



The importance of the role of the graphical Web browser itself should not be 
overlooked. As well as the ability to support multiple scripting languages, a Web 
browser should provide built-in suppon for standard media types, and the ability :o 
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load and execute programs in the ciient, amongst other fearares. These browsers may 
be viewed as operating systems for WWW interaction, 

WWW and the Telephone Network 

It is possible to provide a telephony service over the Internet between connected 
terminals by digitising voice input and sending it over the Internet in discrete packets 
for reassembly at the receiving terminal. This is an example of a communication 
service on the Internet. Conversely, it is possible to point to a variety of information 
services provided over the telephone system, such as the Miniiel system widely 
available in France. However, these encroachments into each anothers traditional 
territories pose no real threat to either the Internet or the public telephone system. 

Of more Lrsierest are areas of cooperative use of the Internet and the telephone system. 
In fact, ooe such area has existed for some considerable time and has been outlined 
above v»» icb reference to Figure 4, namely the use of a modem link over the PSTN from 
a user ccrrouter 34 to an Internet service provider 33 in order to obtain dialup IP 
access to ir^e Internet. This cooperative use is of a ver>' simple r^mre, Pxameiy the 
setting ur o: a bearer channel over the PSTN for s^ubsequently generated Internet 
trafrlc: ~s^r^ is no true interaction between che Internet a."d the PSTN. 

Anotfcrr kiisiDwn example of the cooperative use of the Internet and PSTN is a recently 
laimciheii service by which an Internet user with a sound card in his/her terminal 
compear — make a voice call to a standard telephone anywhere in the world. This 
— f by transferring digitised voice over the Internet to a service pro\ider near 
jon telephone; this service provider then connects iruo the local PSTN to 
access zz^ ziesired phone and transfers across into the local PSTN the voice traffic 
rec^:-.-^ — =er the Internet. Voice input from the called telephone is handled in the 
— versst r==ier. Key to this service is the abilit>' to identify' the ser/ice provider local 
(i- :^::rrr5E=ir.- charging terms) to the destination phone. This arrangemeni. whilst 
offet — -3 — ^ orospect of competition for the telecom operators for long dirLance calls. 
is - ^ srmple chaining together of the Internet and PSTN. It may. however, be 
rK>Ls=c — — — this case it is necessary to provide at least a minimum of feedback to the 
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Iniemei calling pam' on the progress of call set to ihe destination telephone over the 
PSTN local to that telephone; this feedback need only be in terms of v^heLher or not 
the call has succeeded. 

5 From the foregoing it can be seen that the current cooperative use of tJie Internet and 
telephone system is at a very simple level. 

It is an object of the present invention to provide a method of accessing a service 
resource item over a communications network that facilitates the integration of the 
10 PSTN and the WW^^^ 

Summary^ of the Invention 
According to the present invention, there is provided a method of accessing service 
resource items for use in respect of setting up bearer channels through a switched 
15 telecommunications system, the method including the steps of: 

(a) " provisioning at least one server connected to a computer network with a 

plurality of service resource items that are thereafter locatable on said computer 
network by corTesf>onding known URIs. said computer network being logically 
distinct from the telecommunications system^ and said service resource items 
20 relating to setup control for bearer channels through said telecommunications 

system with each said service resource item being associated with a respective 
predetermined code, said predetermined codes being distinct from said URJs 
and identifying end-point entities for said bearer channels; 

(b) — providing a mapping between each said predetermined code and the said known 
25 URI of the service resource item associated with that predetermined cede; and 

(c) — utilising a said predetermined code to access a corresponding said service 

resource item by using said mapping to determine the URJ corresponding to that 
resource item and then using this URI to access the service resource item over 
said computer network. 

30 

In one embodiment, at least some of the URIs are derivable from their corresponding 
said predetermined codes by manipulation according to a function specified by said 
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mapping. In another embodimeni, at least some of the LrRJs are derivable from their 
corresponding said predetermined codes by look up in an association table associating 
said predetermined codes and URIs according to said mapping. This association table 
can advantageously be held on at least one database serA^er connected to the conr.puter 
5 network, step (c) involving accessing the database server over the computer network 
to determine the URI corresponding to the said predetermined code. Preferably, the 
said at least one database server is provided by a DNS-ryp>e distributed database system 
in which the URIs are held in records associated with respective names, herein referred 
to as domain names, by which the records can be retrieved. In this case, step (c) 
10 involves translating said predetermined code into a corresponding domain name and 
using this domain name to retrieve the URI of the required sen^ice resource item from 
the DNS-r\pe distributed database system. 

More than one service resource item can be located at the same URI; in this case, the 
15 predetermined codes of these service resource items will include respective relative- 
resource-identifier values that can be used at the server holding the service resource 
items to -Identify the required resource item amongst the service resource items at ihc 
same URI. 

20 The telecxr^mmunications system may be a telephone system with each said 
predeteroiined code being either the telephone number of the calling party or the 
telephone number of the called party (these numbers may either be the numbers of 
specific ^sk:5)bones, or personal numbers). In one preferred embodiment where at least 
some of said predetermined codes are caJled-parry telephone numbers, the 

25 corresponfii-g ser^^ice resource items are the current telephone numbers of the called 
parties. 

General::- ^ regards the nature of the service resources, ihese may be of the following 
type: 

30 - >^--ice logic intended to be executed by the corresponding ser\-er upcr. being 
— ^^ ^fi with the result of this execution being reoirr.ed to the accessing entity: 
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downloadable service data which upon being accessed is intended to be 
downloaded to the accessing entity; 

downloadable service logic which upon being accessed is intended to be 
downloaded to the accessing entity for execution thereby. 

5 

Preferably, where URIs are referred to in the foregoing, these URIs are URLs and/or 
URNs. Furthermore, the servers referred to are preferably HTTP servers. 

It is to be understood that reference in the foregoing to the computer network beine 
10 logically distinct from the telecommunications system is not to be taicen to imply that 
there is physical separation of the two - indeed, there will frequently be joint use of the 
same physical infrastrucmre. Funhermore, not only may bearer channels set up in the 
telecommunications system share the same transmission medium as the computer 
network, but such a bearer channel may act as a pipe for traffic across the computer 
15 network. -The^ intention of requiring the computer network to be logically distinct from 
the telecommunications, system is to exclude computer networks that are dedicated to 
the management or monitoring of the bearer network and effectively form part of the 
telecommunications system itself. 

20 Preferably, the computer network is generally accessible to users of the 
telecommunications system as this provides a number of benefits to users that will 
become apparent hereinafter. The phrase "generally accessible" should not be construed 
as meaning that all users of dtie telecommunications system have such access to the 
computer network or can get such access but, rather, it should be understood as 

25 meaning that a significant proportion of these users have or can obtain access to the 
computer network. 

By way of example, in one preferred embodiment of the invention, the compu.-r 
network generally accessible to users of the telecommunications system but logically 
30 distinct from it, is the Internet and the telecommunicatioas system is a public telephone 
system. In another embodiment, the telecommunication system is a private system 
including a PABX, and the computer network is a LAN. 
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Brief Description of the Dra\%nngs 
Embodixnenis of the present invention will now be described, by way of non-limiting 
5 example, with reference to the accompanying diagrammatic drawings, in which: 
.Figure 1 is a simplified diagram of a standard PSTN; 

.Figure 2 is a simplified diagram of a known PSTN with IN ser\'ice capability; 
.Figure 3 is a diagram illustrating host domain name resolution by the DNS of the 
Internet; 

10 .Figure 4 is a diagram illustrating the functioning of the World Wide Web; 
.Figure 5 is a diagram illustrating the format of a staiKlard URL; 
.Figure 6 is a diagram of a first arrangement in which service resource items are 
held on HTTP ser^'ers accessible both by the ser^*ice conu-ol subsystem 
of a PSTN and by Web users; 
15 .Figure 7 is a diagram illustrating the processing of a serv ice request by the SCP 

of Figure 6; 

.Figure S is a diagram illustrating the format of a resource code used by the 
Figure 6 SCP when accessing a service resource item; 

-Figure 9 is a diagram illustrating the process of accessing a sen-'ice resource m 
20 the case where the service code does not include an RRI part; 

.Figure 10 is a diagram illustrating the process of accessing a service resource in 
the case where the service code includes an RJRJ part; 

.Figure 11 is a diagram illustrating the derivation of the URI of a service resource 
by parsing an input telephone number in accordance with the present 

25 invetion; 

-Figure I2A is a diagram depicting a name space (the "telname space constioited 
by the domain names derived by a parsing of a predetermined set or 
telephone numbers; 

.Figure 12B is a diagram depicting the incorporation of the telname space without 
30 fragmentation into the DNS; 

-Figure 12C is a diagram depicting the incorporation of the telname space m 
fragmented form into the DNS; 
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-Figure 13 is a diagram illustrating the overall operation of the Figure 6 
arrangement in providing a roaming number service in response to a 
telephone number being dialled at a standard phone; 

.Figure 14 is a diagram illustrating the overall operation of the Figure 6 
5 arrangement when utilised by a Web user in setting up a call through a 

telephone interface integrated into the user's Web terminal; 

.Figure 15 is a diagram illustrating the overall operation of an arrangement in 
which an interface is provided between the PSTN and the Internet for 
telephone traffic; 

10 .Figure 16 is a diagram illustrating the overall operation of an arrangement in 
which a call seoip gateway is provided between the Internet and the 
PSTN; 

.Figure 17 is a diagram illustrating the overall operation of an arrangement in 
which a freephone service is implemented for Web users; and 
15 .Figure 18 is a diagram similar to Figure 6 illustrating the provision of a distributed 
processing environment for interconnecting elements of the sen'ice 
control subsystem of the PSTN. 



20 Best Mode of Carrying Out the Invention 

Figure 6 illustrates an arrangement for the provision of services in a PSTN 
conventionally comprising an inter-exchange network 13 (including trunks and switches 
at least some of which are SSPs 41 with associated IPs), an access network 11 
connecting customer permise equipment (here shown as telephones 40) to the network 

25 13, and a service control subsystem 42 including at least one SCP for providing 
services to the SSPs 41 upon request. It will be appreciated that the Figure 6 
representation of a PSTN is highly diagrammatic. 

The SCP 43 may operate in a conventional manner responding to service requests from 
30 SSPs 41 to run specific service logic on particular data according to information 
contained in the service request, and to send back to the requesting SSP appropriate 
instructions for effecting call set up. A service request is generated by the SSP in 
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response to predeiermined trigger conditions being met at a tngger check point, there 
being one or more such check points in the course of handling a call (it may be noted 
that where the trigger conditions have been downloaded to the SSP from the SCP then 
it could be said that the SSP is responding to an information request by the SCP when 
conucting the SCP upon the trigger conditions being met - however, in the present 
specification, this initial communication from the SSP to the SCP will be referred to 
as a "service request"). 

The SCP 43 is also provided with a network access interface 44 to the Internet 50 m 
order to make use of certain service resource items 49 (also referred to below simply 
as "service resources ') during the course of processing at least certain service requests 
from the SSPs 41. These service resources 49 are held as WWW pages on HTTP 
ser\'ers 51 (more particularly, on service resource databases 52 of these servers 51). 
The Wl^'W' pages containing these service resources are referred to below as "phone" 
pages. Tbe servers 51 are connected to the Internet and the phone pages are read 
accessible using respective URLs or URNs (for convenience, the more general term 
URI w-iii be used hereinafter to mean the Internet-resolvable indicator of the location 
of a phone page). 

Tbe sen^-i^e resources may be service logic or service daia and may be used by an 
otherwise scajxlard service logic program running on the SCP. by accessing the phone 
page of :±>e required resource using the appropriate URI. In certain cases, the service 
resources 49 may provide substantially all of the service control and data associated 
with a psracalar service. In this case, the service logic program rurming in the SCP 
43 is of sfcsieton form, being instantiated on receipt of a service request and then 
serving to trriiiate service resources access and to return the results of this access to the 
enriry- tK-- — z^-i f- the service request. In fact, according to this approach, the SCP could 
be iir:z:iez=^e=red simply as a platform for fetching and executing phone-page ser^'ice 
logic ^^zjuld not need to have the complex provisioning and management systems 

for such ir^^ as is required by sundard SCP platforms; SCPs could then becom.e more 
ubiqu±icci£^ rossibly being associated with every SSP. 



wo 97/22212 PCT/GB96/03055 

22 

Figure 7 is a flow chart illustrating the progress of events in the case where the SCP 
43 handles a service request by accessing a phone-page service resource. Upon receipt 
of a service request in an INAP message (step 100), SCP 43 decodes the TCAP/INAP 
message structure in standard manner (steps 101 and 102) well understood by persons 
5 skilled in the art. Next, SCP 43 instantiates a service logic program, SLP, to handle 
the request (step 103). This SLP is then responsible for looking up the URL of the 
required service resource as determined from infonnation contained Ln the ser\ice 
request (steps 104, 105). For example, if the service request relates to a called-pany 
service, then the required resource will be indicated by the dialled number and the 

10 latter will be used to derive the URL of the resource. Once the URL of the desired 
service resource has been ascertained, a resource request (for example, in the form of 
an HTTP request message) is sent over the Internet to the corresponding serv er holding 
the desired service resource (step 106); a correlation ID is also passed with the 
resource request to enable a response from the latter to be linked with the appropriate 

15 SLP insunce. A timer is also started (step 107). 

If a response is received from the accessed resource before the expiration of a time-ou: 
period (tested in step 108), then the response, which is usually in the form of a 
destination number, is supplied to the appropriate SLP as identified using the 
20 correlation ID passed with the response (step 109). An INAP. TCAP response message 
is then prepared and sent to the entity that made the original ser\'ice request (steps 1 10 
and 111) after which the SLP instance is terminated (113). 

If in step 108, a time-out occurs before a response is received, then a default response 
25 value (generally a default destination number) may be looked up in the customer record 
and put in an INAP/TCAP message and sent back to the requesting entity (steps 114 
to 116). The SLP instance is then terminated (113). 

Locating & Accessing Service Resources 
30 The functionality associated with accessing a phone-page resource is schematically 
represented in Figure 6 by resource access block 46. Block 46 includes URI 
determination block 47 for determining the URI of the phone page containing the 
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desired resource on the basis of parameters passed to block 46. Using the LTRJ rerumed 
by block 47, the resource access block 46 then accesses the phone page of the required 
service resource 49 over the Internet through interface 44. 

Resource Codes - It is possible that more than one service resource is associated with 
a panicular telephone number; in this case the resource access block 46 will need to 
know additional information (such as current point- in-call, pic) to enable the 
appropriate service resource to be identified. If the service resources associated with 
a number are located on different phone pages, then the additional information is also 
passed to the URI determination block 47 to enable it to return the URI of the 
appropriate phone page. It is also possible for all the service resources associated with 
a number to be located on the same phone page. In this case, the resource access block 
46 uses the additional information to pass a resource-identifying parameter^with its 
access request to the phone page concerned; it is then up to the functionality associated 
with the phone page to access the correct service resource. 

Thus, each service resource can be considered as being identified by a respective 
resource code 54 (see Figure 8) made up of a first part UI ("URI Identifier') used to 
identif\- the URI at which the resource is located on the Internet, and a second part RRJ 
("Relative Resource Identifier") used to identif>' the resource amongst plural resources 
at the same URI. 

Resource Access - Where only one service resource 49 is located on a phone page 58 
identified hy a unique URI, then the resource code 54 simply comprises the Ul, 
ger^eraliy either a telephone number alone or a telephone number plus a pic parameter 
(see Rgure 9). In this case, accessing a resource simply involves mapping the whole 
rescur:^ -ole 54 into the corresponding URI (process 55) and then sending a request 
57 lo :x:-rTesponding phone page 58, this latter itself constiaiting the desired service 
resource ^9 The result of accessing resource 49 is then remmed in respor^ message 
59. 
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In contrast, where multiple service resources 49 are located on the same phone page 
58 (Figure 10), the resource code 54 comprises both a UI and RRI, the UI generaiiy 
being a telephone number and the RRI a pic or other parameter for distinguishing 
between the co-located resources. In this case, accessing a resource involves mapping 
the UI pan of the resource code 54 into the corresponding URI (process 55) and then 
sending a request 57 to the corresponding phone page (process 56), the request 
including the RRI of the resource code. The phone page 58 includes functionality 64 
for accessing the required resource on the basis of the RRI in the request message. The 
result of accessing the required resource 49 is then rerumed in response message 59. 

An alternative to the Figure 10 method of accessing a service resouce that is co-located 
with other resources on a phone page, would be to retrieve the whole page across ths 
Internet simply using the URI derived from the UI part of the resource code, and then 
to extract the desired resource on the basis of the RRI. 

URI Determination from Resource Code - The implementation of the URJ 
determination block 47 that performs process 55 will next be considered. Block 47 rrisy 
be implemented in a variety of ways, four of which are described below: 



20 Direct Input 

It would be possible, though not necessarily convenient, to arrange for the 
calling parry to input directly the required URI. The calling party may thus 
input the host id component of the URI required (either in the form of a host 
domain name or host IP address) plus the path component of the URI. For 

25 example, in the case where the phone page of a called party is to be accessed. 

the calling parry may input the URI of the called party and, indeed, this inpu: 
may substitute for the normal input of a telephone number. A leading inpu: 
string (for example "999") may be used to identif)- the input as an URJ. .\s 
regards the input means, where a user only has a standard 12 key telephone. 

30 input of host domain names and other URI elements requiring alpha characters. 

will need to be done using one of the standard techniques for alpha input frcrr. 
a phonepad (such techniques are already used, for example, to enable a calling 
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party to "spell" out the name of the called part>). It would also be possible to 
provide user^ with a full alphanumeric keypad to facilitate URl input. 

Computation 

5 Service resource access over the Internet could be restricted to a set of dialled 

numbers from which it was possible to compute a corresponding URI; in this 
case, this computation would be the responsibility of block 47. 

Association Table Lookup 

10 Probably the simplest implementation for the block 47 is as an association table 

(either in memory or held on database disc store 48) associating a URI with the 
UI pan of each resource code. A potential problem with this approach is that 
a service resource may be required for a called pany number on th,e other side 
of the world which implies a rigorous update regime between PSTN operators 

15 worldwide in order to keep the association table up-to-date. (Note that the same 

implication is not necessarily applicable in respect of marking the called-party 
number as one required to trigger a ser/ice request, since the number may be 
arranged to be one of a group of numbere all triggering an appropriate" service " 
request, in a manner similar to 800 numbers). 

20 

DNS-Type Lookup 

An alternative lookup solution is to use a hierarchically-structured distributed 
database system, similar to (or even part of) the Domain Name System (DNS) 
of the Internet, in order to resolve the UI part of a resource code to a 
25 corresponding URI. This approach, which will be described in more detail 

below, would typically involve databases mainuined by each PSTN operator for 
Its numbers with which URIs are associated. These daubases would be 
accessible by all PSTNs through a nerwork such as the Internet with resolution 
requests being pointed to the appropriate database in a manner similar to the 
30 Domain Name System. In this case, the block 47 is constituted by an 

appropriate resolution program arranged to request UI resolution over the 
In'^met through interface 44. 
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Before describing a DNS-type lookup implementation for the URI determination block 
47. some further general comments are appropriate. Whatever method is used to 
determine the URI, certain simplifications are possible if limited constrainLs are placed 
on the URIs peirnitted. In particular, it is not necessar>' to determine a]] components 
5 of an URI in the following cases: 

(i) A part of the URI path component can be made standard for all service 
resources, this standard part being simply added by Lhe block 47 once the rest 
of the URI has been determined. For example, where a roaming number is to 
be looked up, it may by convention always be held in a fde •roam" in a 

10 subdirectory "tel" of a subscriber's directory on a particular ser\'er. In this case 

the URI host component and the subscriber-unique part of the path component 
are first determined aiKl then the remaining path pan *7tel/roam" is added. 

(ii) The URI path component can be arranged to be the same as a predetermined 
part of the resource code, the block 47 needing only to detennine the host 

15 component and then add the path. For example, it may be agreed that the path 

must always end with the telephone number concerned, or sufficient of the 
terminating digits to have a high probabiliw of uniqueness on the host machine. 
The path may also include standard components to be added by block 47. 

(iii) Blocks of telephone numbers may have their corresponding service resources 
20 located on the same host server so that it is only neces$ar>' to use a pan of the 

telephone number to determine the host component of the URI; in this case, the 
path component can conveniently include all or pan of each telephone number. 
This simation implies a tight degree of control by the telephone operators and 
does not offer the telephone user the freedom to choose the host ser^-er on 
25 which user places their phone page. 



Another general point worthy of note is that however the URI is determined, the host 
component of the URI may be provided either in the form of a host domam raine or 
a host IP address. Where the host is identified by a domain name, then a further 
30 resolution of URI host name to IP address will subsequently be carried out in standard 
manner by interface 44 using the Domain Name System, of the Interne:. Tnis further 
resolution can be avoided if the host identity is directly provided as an IP address. 
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Where a database lookup is used to provide the number to URI translation, this 
database may be independent of. or combined with, a customer database containing 
other customer-related information. Factors affecting this choice include, on the one 
hand, the possible desirability of having the number-to-URI translation mformation 
5 widely available, and on the other hand, the possible desirability of restricting access 
to other customer-related information. 

r»J5;.Tv pf^ I mi lookup 

A DNS-type lookup implementation for the URI determination block 47 will now be 
10 described in some detail for the case where the UI pan of the resource code is a 
telephone number and there are no constraints on the URI. thereby requiring both the 
full host and path components of the URI to be returned by the lookup. A key part of 
the overall process is the formation of the equivalent of a host domain name from the 
telephone number of interest; this domain-name equivalent is then resolved into a 
15 corresponding URI by a lookup mechanism which in the presem example is identical 
to that employed by the DNS (indeed, the lookup mechanism may be incorporated into 
the DNS though it can also be independently implemented). 

The nawre of the DNS has already been described above with reference to Figure 3 
20 when the term "DNS-type" system was also introduced. For convenience in the 
following a DNS-type system organised to provide a telephone number to URI 
translation facility will be referred to as a "Duris" system (standing for "DNS-type URI 
Server" system). 

25 The basic principles surrounding operation of a Duris system are: 

- ever>' telephone number can be turned into a host domain name (the name 
space containing such host domain names for the telephone numbers of interest 
is referred to below as the "telname space"); and 

- for every host domain name in the host domain space there is a Registration 
30 Record held by the Duris system containing the corresponding URI. 

Thus, an input telephone number forming, in the present case, the Ul pan of a 
resource code 54 (see Figure 11). is first parsed to form a domain name (step 120) and 
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then passed to the Duris system (illustrated in Figure 1 1 as fonned by the DNS itselQ 
to retrieve the RR with the corresponding URI (step 121), Following on from the URI 
lookup, if the URI returned has its host component as a domain name, the DNS is next 
used to derive the host IP address (step 122); this step is, of course not needed if the 
5 host component is stored as an EP address in the RR. The URI is then used to make a 
resource request to the appropriate server, passing any RRI part of the resource code 
54 (step 123). 

There are a number of possibilities at the top level as to how a Duris system could be 
10 implemented; 

(a) Independent of the DNS. In this option, the telnam.e space constitutes the entire 
name space to be managed with the root of the telnarae space being the " 
name space root (see Figure 12A where the telname space is shown hatched). 
In this case, the Duris system is independent of the DNS itself. The Duris 

15 system could, of course, use the same basic infrastructure as the DNS (that is. 

the Internet) or an entirely separate network. Where the telname space 
comprises all the domain names corresponding to all public telephone numbers 
worldwide, parsing a full international telephone number would give a fully 
qualified domain name. Of course, the telname space could be a much smaller 

20 set of names such as those derived from internal extension numbers within a 

company having worldwide operations. 

(b) Unfragmented Telname Space within the DNS. In this option, the telname space 
is a domain of the DNS name space and the Duris system is provided by the 
DNS itself. Thus, where the telname space comprises all domain names derived 

25 from public telephone numbers worldwide, the telname space could be placed 

within the domain of the ITU, in a special subdomain "tel", the root of the 
telname space then being "tel.iru.int.** (see Figure 12B where again, the hatched 
area represents the telname space). The responsabiiir>' for administering the 
domain "tel.itu.int." would then lie with the ITU. With this latter example, to 

30 form a fully qualified domain name from an input telephone number, after the 

number has been parsed to form the pan of the domain name corresponding to 
the structuring wiihin the telname space, the tail "lel.itu.int. " is added. The 
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fully qualified domain name is then applied to the DNS and the corresponding 
RR record, holding the required URl, is retrieved. As a further example, the 
telname space could be all name derived from internal extension numbers within 
Hewlett-Packard in which case the root of the telname space would be 
5 "tel.hp.com." and Hewlett-Packard would be entirely responsible for raaiuging 

this domain. 

(c) Fragmented Telname Space within the DNS. In this option, the telname space 
is split between multiple domains of the DNS name space and the Duris system 
is provided by the DNS itself. Thus where the telname space comprises all 

10 domain names derived from public telephone numbers worldwide, the telname 

space could be split between respective "tel" subdomains of each countrs' 
domain; thus, as illustrated in Figure 12C, the part of the telname space 
corresponding to French telephone numbers would have a root of "tel.fr." and 
the pan of the telname space corresponding to UK telephone numbers would 

15 have a root of 'tel.uk. The responsability for administering each "tel" 

suboomain would then lie with each country. With this latter example, to form 
a felly qualified domain name from an input telephone number, the pan of the 
te!erh<Tie number following the country code is parsed to form the" part of the 
CO— ^ir. name within a country tel' subdomain anc then a host domain name tail 

20 is added appropriate for the country concerned. Thus for a French telephone 

tnrmber, the "33" country code is stripped from the number prior to parsing and 
use:i CD add a tail of "tel.fr.". The tail appropriate to each country can be stored 
ixi a local lookup uble. As a further example, two commercial organisations (X 
cCTzpany and Y company) with respective DNS domains of "xco.com." and 

25 "-.-cc -xom." may agree to operate a common Duris system with a telname space 

5e^_-. ■r»etween 'tel.xco.com." and "tel. yco.com". In this case, any Y company 
--^:^zi3ne number input from X company will be parsed to a fully qualified 
- — ^ name terminating "tel. yco.com." and vice versa. 



30 Cor^-.i=r 
nzsnc - - 
the sz.-^ 
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are hierarchically structured according to each countr\''s numbering plan. Thus one 
approach would be to follow this numbering plan structuring in dividing up a telephone 
number to form a domain name. By way of example, the telephone number 
"441447456987" which is a UK number (countr\' code "44") with a four digit area 
5 code ("1447") and six digit local number ("456987") could be divided to form a 
domain name of 456987.1447.44 (note that the reversal of label order occassioned by 
the fact that the DNS labels are arranged least significant first). If the telname space 
is a subdomain of the DNS with a placement as illustrated in Figure 12B, the fully 
qualified domain name derived from the telephone number would be; 
10 456987. 1447.44.iel.iru.int. 

There are however, difficulties inherent with trv'ing to match the numbering plan 
hierarchy when parsing a telephone number into a host name. Firstly, in order to parse 
an international number correctly, it would be necessary for each entit>' tasked with this 

15 operation to know the structuring of each countr>''s numbering plan and where, as in 
the UK, area codes may be of differing length the required knowledge may need to 
take the form of a lookup table. Whilst this is not a complicated ccmputationai task, 
it is a major adminisU"ative nuisance as it means thai each countr>' will need to inform 
all others about its numbering plan and any updates. The second problem is thai a six 

20 or seven digit local number is a very large domain: it would be preferable to create 
subdomains for performance and scaling reasons but there is no obvious way of doing 
this. 

These problems can be overcome by giving up the restriction that the parsing of 
25 telephone number into a domain name should match the structuring of rational 
numbering plans. In fact, there is no strong reason to follow such a scheme as DNS 
servers know nothing about the meaning of the name space. It is therefore possible lo 
parse telephone numbers using a deterministic algorithm taking, for example, 4 digits 
at a time to limit the size of each subdomain and making it possible to 'iasen the dots' 
30 without knowing the numbering plan concerned. So long as the DNS domains and 
zones served by the DNS servers are created correctly it will all work. 



10 
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Por iniemaiional numbers it would still seem appropnate to separate off the counir>' 
codes and so a hybrid parsing scheme would be to parse the initial part of a dialled 
number according to known country codes and thereafter use a deterministic scheme 
(for example 3,7 or 4,6 or 3,3,4) to separate the digits. Of course, if a fragmented 
telname space is being used as illustrated m Figure UC then the country code is used 
to look up the host name uil and it is only the national part of the number which would 

FinaJN , ^ regards the details of how a DNS server can be set up to hold RR records 
^ l-ICs, reference can be made, for example, to "DNS and BIND", Paul Albitz and 
Cr^ec : jr, O'Reilly & Associates, 1992 which describes how to set up a DNS ser^•er 
'-^rag rrsf urux BIND implemeniation. The type of the RR records is, for example, 



'5 I: Kixn^i^ ^ noted that DNS labels should not in theorv' surt with a digit. If this 
-r—'^^r:;-,^ retained, then it is of course a trivial exercise when parsing a telephone 
— insert a standard character as the first character of each label. Thus, a 4 
ccLgrn ji^zr^ 2826 would become "t2826'' where "t" is used as the standard staning 



20 



ssDreciated that as with domain names, where an input telephone number is 
ncx *rs —-I xsumber (for example, a local call does not require any international or area 
— . . ii would be parsed into a domain name in the local domain. 

25 TJrs: -. ^g discussion of Duris system implementation, has been in terms of 



telephone number into an URI where the telephone number forms the full 
~' - "ifTP code and the Duris system renims a full URI. It will be appreciated 

Lhar .. ^ ^ riK/>H Duris implementation can be readily adapted to accommodate the 

-£iification discussed above regarding the form of the UI and what parts of 



30 the ZIEZ^ to be looked up. For example, where there are a number of differents 

se: rz^ -::=^urces associated with a subscriber each in its own file and the required 

sc^^^=zi: jzi^ntified by a pic part of the resource code, then the input telephone number 



wo 97/22212 PCT/GB96/03055 

32 

will be used to look up, not the full URI, but ihe host component and that part of the 
path component up to the relevant subdirector>\ the pic part of the Ul then being 
appended to identify the required resource file. 

5 For small local Duris implementations, it may be possible to have a single server; the 
implementation should still, however, be considered as of a DNS type provided the 
other relevant feamres axe present. 



10 Nature of Service Resources 

Turning now to a consideration of the service resources 49, how these service 
resources can be provisioned onto the ser\'ers 51 will be described more fully below 
but, by way of present example, the ser\'ice resource or resources associated with a 
particular PSTN user (individual or organisation, whether a calling or called party) can 

15 be placed on a server 51 over the Internet from a user terminal 53 in one or more 
WWW pages. 

Consider the simple case where the service resource is a service data item such as a 
telephone number (for e.xample. an alternative number to be tried if the user's 

20 telephone corresponding to the number dialled by a calling parc>' is busy). This 
diversion number could be made the sole service resource of a phone page of the user. 
The phone page URI could be a URL with scheme set to HTTP in which case the GET 
method could be used to retrieve the diversion number. Such an arrangement is suitable 
if the phone page is only to be used for functional retrieval of the diversion number. 

25 However, if the diversion number is to be visually presented at a user iermii:al 53, then 
it may be desirable to accompany the number with explanator>' material (this will often 
not be necessary as the diversion number can be arranged to be rerumed into an 
existing displayed page that already provides context information). However, where the 
phone page does include explanatory material as well as the diversion number, an 

30 entity only wishing to make functional use of the phone page, could be arranged to 
retrieve the phone page and then exuact the diversion number (this would, of course. 
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require a standard way of identif>'ing the information to be extracted from the phone 
page). 

An alternative and preferred arrangement for providing for both viewing and functional 
5 access to a resource requiring explanatory material for viewing, is to use an object- 
oriented approach to resource design. In this case, the resource object would have two 
different access methods associated with it. one for purely functional use of the 
resource and the other enabling viewing of associated explanatory material. It would 
then be up to the accessing entity to access the resource object using the appropriate 
10 object method- 

Yet another arrangement for providing for both viewing and functional use of the 
diversion number, would be to provide separate resources appropriately configured for 
each use. each resource having its own resource code (generally, both such resources 
15 would be placed on the same phone page and in this case the LI pan of each resource 
code would be the same). 

Retrieval of a phone page for use by a human user will generally not be as time critical 
as retrieval for operational use by a PSTN. Thus. whi.. for human use the- scheme 
20 specified in the URL of a service resource could be HTTP, it may be advantageous for 
operational use to defme a special "phone" scheme (access protocol) which would 
result in the server 51 using an optimised access routine to access the required resource 
(diversion number, in the current example) and respond to the accessing entity in the 
minimum possible time. 

25 

Besides data items, other possible types of ser^•ice resource include ser.ice logic for 
execution in place (at the server) with ihe result of this execution being reramed to the 
entity accessing the resource; service logic downloadable from the server to uhe 
accessing entity for execution at that entitv-; and a logging resource for logging 
30 information passed to it by the accessing entity (or simply for logging the fact that is 
has been accessed). It will be appreciated that uhe logging resource is really just a 
panicular =ase of service logic execuuble in place. 
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By way of example, a service resource constituted by execute-in-piace service logic can 
be arranged to implement time-of-day routing, the result of executing the service logic 
being the telephone number to which a call should be routed taking account of the time 
of day at the called party's location. An example of a service resource constituted by 
5 downloadable service logic is service logic for controlling calling-party option 
interrogation using the facilities provided by an IP, As regards the logging resource, 
this can be used for recording the number of calls placed to a panicular number. 

Where each resource has its own phone page and the resource is present only in its 
unembellished functional form, then the HTTP scheme can be employed for access 
using the GET method for both the downloadable service logic and the execution-in- 
place service logic, and the POST method for the logging resource. If it is desired to 
provide an explanatory material with each service resource, then any of the solutions 
discussed above in relation to data items, can be used. 

Where more than one service resource is to be associated with a number, then each 
such resource can be placed on a respective phone page with its own URJ. However, 
the preferred approach is to place all such service resources on the same page and use 
the RRI part of the corresponding resource codes to enable access :o the appropriate 
resource. The accessed resource is then treated according to its form (executed if 
execuie-in-place service logic, returned if downloadable ser\'ice data or logic). 

Thus if both a diversion-number service-data resource and a time-of-day execution-in- 
place service-logic resource are placed on the same phone page, the diversion-number 
25 resource code might have an RRI of ' whilst the time-of day resource cede might 
have an RRI value of "2**. 

Where calling/called party options are to be included in a ser\'ice resource for 
presentation to such party, then as already indicated, this can conveniently be done by 
30 constituting the service resource as downloadable service logic with the chosen option 
possibly initiating request for a follow-up service resource. 



10 
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II wiU be appreciated that a service resource will often be of a complex type, 
combining service data and/or downloadable service logic and/or execute in place 
service logic. A particularly powerful combination is the combination of the two types 
of service logic where the downloadable service logic is designed to interact with 
5 execute-in-place service logic; using this arrangement, the user can be presented with 
complex client-server type applications. 

F.xample TIsaye o f Service Resource 

Figure 13 illustrates the operation of a service making use of a resource on a server 
10 51. This service is equivalent to a "personal number" semce by which a user can be 
accessed through a single, unchanging number even when moving between telephones 
having different real numbers. To achieve this, the user requiring this service (user B 
in the current example) is allotted a unique personal number (here referred to as the 
"Webtei- number of B) from a set of numbers all of which have the same leading 
15 number siring to enable an SSP to readily idenufy a dialled number as a Webtei 
number. User B has a service resource 49 on a dedicated phone page on HTTP seiver 
51.. this phone page being located at a URL here identified as "URL (B phone page)". 
B's phone page when accessed returns the current roaming number (" B-ielNb") where 
B can be reached. In the simplest case, B's phone page is just a single number that can 
20 be modified by B (for example, from a terminal 53) as B moves to a different phone. 
More likely is that B's phone page is an execute-in-place service logic providing time 
of day routing. 

In the present example, the association between B's Webtei number and the URL of 
25 B's pccce page is stored in an association table accessible to SCP 43. 

Upon ^ -aser A seeking to contact user B by dialling the Webtei number of B. the 
iele?hor.e 40 being used by A passes a call set up request to SSP >1 (note that in 
Figure 13 the bearer paths through Lhe telephony network are shown by the thicker 
30 Unes €C . the other heavy Unes indicating signalling flows). SSP 41 defects the dialled 
number as a Webtei number and sends a service request to SCP 43 together with B's 
Webtsi number. SCP 43 on receiving this service request initiates a ser%-ice logic 
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program for controlling translation of B's Webtel number into a current roaming 
number for B; in fact, in the present case, this program simply requests the resource 
access block 46 to access the service resource identified by B's Webtel number, (that 
is, B's phone page 49) and reaum the result of this access. To this end, block 46 first 
5 translates B's Webtel number into the URL of B's phone page and then uses this URL 
to access B's phone page over the Internet (for example, using the 'phone' scheme 
already referred to with a method corresponding to the HTTP GET method). This 
results in B's current roaming number B-telNb being passed back to block 46 and in 
due course this number is returned to the SSP 41 which then initiates completion of call 
10 set up to the telephone 40 corresponding to B-telNb. 

The Figure 13 example related to a called-parry ser\*ice; it will, of course, be 
appreciated that the principle of accessing service resources over the Internet can be 
applied to all types of services, including both calling-part>' and called-parry services 
15 and hybrids. Thus, standard 800 number services can be implemented with the dialled 
800 number resulting in access to a phone page resource constituted by execute-in-place 
service logic that returns the most appropriate number for controlling onward ca!i 
routing. 



20 It will be appreciated that although in the Figure 13 example the service request from 
the SSP was triggered by a leading number string of a dialled number, a service 
request may be triggered by a variety of triggers including calling-party number, 
called-party number, or some other user input, such triggers being possibly qualified 
by call setup progress (for example, called-party number qualified by a busy status or 

25 by ringing for more than a certain time). 



With respect to the logging service resource mentioned above, one possible application 
for such a resource is in telephone voting. In this case, dialling the voting number 
causes the SSP picking up the call to pass a service request to SCP 43 which then 
30 contacts the appropriate logging resource over the Internet to register a vote after which 
the call is terminated. To minimise boulenecks, a logging resource could be provided 
at a different URL for each SCP, it being a simple matter to collect and collate voting 
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from all these logging resources over the Internet. If an SCP with Internet access is 
provided at every SSP. then the risk of congestion is greatly reduced. 

As already noted, a user's phone page may hold multiple service resources in which 
5 case the access request from the accessing SCP needs to contain an appropriaie RRJ 
identifying the required resource. 

In the event that an SCP is to provide both a traditional LX service to some users and 
an equivalent ser^'ice using an Internet-accessed service resource to other usen. then 
10 a lookup table may need to be provided in the SCP to ensure that a serv ice req^jest is 
appropriately handled; such a lookup table can conveniently be combined -^ruh the 
customer record database. 

Once a user, such as user B. has set up one or more phone pages specifying his desired 
15 service resources (panicularly service logic defining persooalised services), it is clearly 
logical for user B to want any PSTN operator he cares to use, to access aixi utilise 
such service resources. This is possible if the Webtel-co-URI databases are ava:lable 
to all operators. Thus multiple operators could be set :o access B's phone page or 
pages. If an operator declines to use B's phone pages. B .an obviously chose i:-. to use 
20 that operator (at least where that operator provides a long haul carrier ser%ice rabject 
to user selection). The possibility therefore arises that service provision will cease to 
command a premium from operators, but that the provision of phone-page utiiisation 
by an operator will become a necessary basic feamre of PSTN operation. 

25 Provisioning and Uixia» inp Service Resources 

Consideration will next be given as to how the ser>'ice resources 49 are provisvoned to 
the ser\'ers 51 and subsequently updated. 

So far as provisioning is concerned, two basic actions are required: firstly, the ser^'lce 
30 resource must be placed on a server 51 and, secondly, the URI of the service resource 
must be nodfied to the PSTN operator along with the trigger conditions (nu^^vcv plus 
any other condition such as point in call) calling for access to the resource: if multiple 
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resources are provided at the same URI, then the RRI values needed to retrieve the 
appropriate resource for a particular trigger condition, must also be notified. This 
notification process will be referred to hereinafter as 'registering* the service resource 
with the PSTN operator; registration is, of course, necessary to enable the association 
5 tables used by SCP 43 to be set up and for trigger conditions to be set in SSPs 43. For 
certain services, such as thai described above with reference to Figure 13, it is not the 
user that supplies the triggering number (the Webtel number in the Figure 13 example): 
instead, the PSTN operator allocates an appropriate number to the user as pan of the 
registration process. 

10 

As to the process of placing a service resource on a server 51, how this is carried out 
will depend on the attimde of the PSTN operator to the possible effects of such service 
resources on operation of the PSTN. Where the service resource simply returns a data 
item to an accessing entity, then an operator may not be too concerned about possible 
15 errors (accidental or deliberate) in implementing the service resource. However, the 
operator will probably be much more concerned about the proper operation of any 
ser\'ice logic that may be returned by a resource; indeed, an operator may not permit 
such a service resource. 

20 Assuming for the moment that an operator has no concerns about the nature or 
implementation of service resources, then how a resource is placed on a server 51 will 
largely depend on the naoire of the server concerned. For example, if a user has a 
computer with network access to the Internet and this computer is used as server 51, 
then the user can simply load a desired resource onto the server as a WWW phone 

25 page for external access. A similar situation arises if the server is an organisation 
server to which the server has access over an internal LAN. In both these latter cases, 
loading the resource as a WWW phone page does not itself require Internet access. 
However, if the server 51 is one run by an external Internet service provider, then a 
user can arrange to- download the required service resource into the user's allocated 

30 Web site space on the ser%'er; this may or may not involve Internet access. One special 
case of this laaer scenario is where the PSTN operator provides a special server for 
user phone pages containing service resources. 
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Except where a user's own computer acts as server 51, placing a service resource on 
a server will generally involve clearing one or more levels of password protection. 

As regards the origin of the service resource loaded by a user onto server 51 . this may 
5 be generated by the user or, particularly where the resource includes service logic, may 
be provided by a third party (including the PSTN operator). 

If the PSTN operator wishes to have control over the service resources 49 to avoid any 
adverse effects on operation of the PSTN, two approaches are possible. Firstly, the 
operator could require that every resource (or. possibly, a panicular subset) had to be 
subject to a verification process before use. appropriate measures then being taken to 
avoid subsequent alteration of the resource by the user (except, possibly, for particular 
data Items); in this respect, the operator could require that the resource be placed on 
a server under the operator's control and to which the user had no write access (except 
15 possibly for altering panicular data items, as indicated above). A second, more 
attractive, approach to minimising adverse effects by the sei^-ice resources 49, is for 
the operator to provide standard service resources to which a user could add the user's 
own data (and possibly make limited functional selections in case where the resource 
included ser%ice logic); the customised resource would then be loaded onto a server 51 
20 controlled by the operator. This process can be conveniently implemented for a 
particular resource using an HTML "fonn' which a user could download over the 
WWW from the operator-conu-olled server. After completing the form and activating 
a 'commit' graphical bunon of the form, the entered information would be 'posted' 
back to the server where the information would be used to produce a customised 
25 service resource thereafter placed on the server for access over the Internet. An 
advantage of this approach is that registration of the service resource with the operator 
is simuiiaaeaously effected, at may be noted that if registration needs to be done as a 
separate act from having a ser\'ice resource loaded on a server, then using an HTML 
form is a \-^ry convenient way to implement the registration process). 

30 

From ihe foregoing it can be seen that whilst the provisioning process does not 
nscesssnly require information to be passed over the Internet, in many cases this will 
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be the best solution, panicularly if an HTML form exchanged over the WWW can be 
used to produce a customised ser\'ice resource. It should be noted that producing a 
customised service resource using an HTML form is not limited to cases where the 
PSTN operator controls the server. 

5 

As regards updating service resources, there is likely to be a need to update certain - 
data items on a fairly frequent basis (for example, roaming number). Where the PSTN 
operator does not place any controls on the service resources 49, then update is a 
relatively simple matter, only requiring write access to the server concerned (as already 

10 indicated, this will generally involve one or more levels of password protection). 
However, where the PSTN operator exercises control over the service resources, for 
example by only permining customisations of standard service resources, such 
customised resources being loaded on servers controlled by the operator), then write 
access to the service resource may be tightly controlled. Again, an HTML form may 

15 conveniently be used as the medium for modifying a data item in such cases; to the 
operator, this has the benefit of limiting the modifications possible whilst to the user, 
a form interface should provide a simple route to resource modification. 

For more complex updates, it may be necessary to go through a process similar to thai 
20 required for initial provisioning. 

Particularly where the service resources are held on a server 51 controlled by the 
PSTN operator, resource update will generally involve communication over the 
Internet. 

25 

Web User Interaction 

Consideration will next be given to other possible uses of the service resources held 
in phone pages on the servers 51. For example, if user B's phone page contains a 
diversion number, then provided this phone page is read-accessible over the Internet 
30 from user A's terminal 53, user A can use a graphical Web browser running on 
terminal 53 to view B's phone page and discover B's diversion number. As earlier 
discussed, the diversion number may be passed to user A for display in an existing 
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visual context giving meaning to the number, or may be passed to user A with 
accompanying explanatory text. 

A more useful example is a current roaming number service for user B. Suppose B's 
phone page 49 on server 51 (see Figure 14) is operative when accessed to return a 
current roaming number where B can be reached. Further suppose that user B has a- 
Web site with several Web pages written in HTML and each page contains a graphical 
•phone' button which when activated uses the GET method to access B's phone page 
by its URL. Now if user A whilst browsing (arrow 66) B's Web site over the WWW 
from user A's terminal 53. decides that he would like to call user B to discuss some 
item of interest, user A simply activates the phone button 65 on the currently viewed 
page of B. This causes B's phone page to be accessed using the HTTP request "GET 
URL (B Phone Page)" - see arrow 67. 



15 B's current number to be called is then determined and passed to user A's terminal 53 
(see arrow 68) where it is displayed. An explanatory text concerning the number will 
generally also be displayed; for example the text "Please call me at the following 
number:" could be displayed, this text being provided either by the HTML script 
associated with the phone button, or from the phone pag- when remming the current 
20 number. In fact, it would probably be more helpful to provide user A, not only with 
the current number for reaching user B, but also with all numbers where B could be 
reached together with the times when B was most likely to be at each number. Since 
this extra information is likely to be subject to frequent change, the only sensible way 
to provide the information is from the phone page. Thus, B's phone page not only 
25 provides the current number for reaching B. but also a text that includes numbers and 
tunes subject to change; scripting B's phone page is, of course, done in a way that 
ensures that variable data need only be altered in one place. 

In a further example, B's phone page might include downloadable service logic for 
30 execution at user A's terminal. This is useful where choices are to be presented to a 
user, each choice producing a follow-up action such as fetching a further phone page. 
For example, the first-accessed phone page may be a family phone page giving the 
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general telephone number for a family but also giving the user the possibility of 
selecting further phone information on each family member, such as a time-of-day 
dependent number; in this case, each family member has their own follow-up phone 
page. 

5 

In the above scenarios, user A has been presented with a number to call over the - 
PSTN. User A can now pick up his standard telephone and dial the number given. In 
fact, a complication arises if A only has Internet access via a SLIP/PPP connection 
over an ordinary, non-ISDN, PSTN line since, in this case, A's telephone line is 

10 already tied up with making Internet access when gateway 90 seeks to set up a call to 
A*s telephone; with an ISDN connection, as two channels are available, this problem 
does not arise. One way of overcoming this problem would be to have user A*s 
terminal 53, after obtaining the number to call from B's phone page, automatically 
suspend its Internet session by storing any required state information (for example, 

15 current WWW URL being accessed) and then terminate its SLIP/PPP connection to 
thereby free up the telephone line. A can then telephone B. At the end of this call, A 
can resume the suspended Internet session, using the stored state information to remm 
to the point where A left off to call B. An alternative approach is to operate a suitable 
multiplexing modulation scheme on the telephone line to A allowing voice and data to 

20 be simultaneously carried. A number of such schemes already exist. The PSTN would 
then need to separate the combined data and voice streams coming from A at some 
point and pass each to its appropriate destination (the Internet data being forwarded to 
the ISP providing the SLIP/PPP connection for user A and the voice stream being 
passed to B); of course, data and voice traffic in the reverse direction would also need 

25 combining at some point for sending over the last leg to A's terminal. 

Rather than A manually dialling B using a standard telephone, another possibility is 
that user A's terminal is provided with functionality enabling A to make a call over the 
PSTN from his terminal; this functionality generally comprises a hardware interface 
30 70 (Figure 14) to a telephone line and phone driver software 71 for driving the 
interface 70 in response to input from application software such as the Web browser 
73. A could call up his phone software and enter the required number or, preferably. 
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A need onJy "select" on screen the number returned from B's phone page and then pass 
it into A's phone software. Indeed, provided user B knew the software interface to the 
software 71 providing dialling functionality on A's terminal, it would be possible for 
B's phone page to remm to A's terminal program code for automatically dialling B's 
number upon A confirming that he wishes to proceed with call placement. As an 
alternative to placing a voice call, if A's terminal is equiped with a suitable modem and 
controlling software, A could, instead, elect to send a fax or data to B through the 
PSTN either to B's ordinary number or to one specified in B's phone page as the 
number to be used for such transmissions. Of course, placing a call from A's terminal 
over the PSTN may be subject to the problem already discussed of conflict for use of 
the telephone line where this is not an ISDN line and A gains Internet access via a 
SLIP/PPP connection. 

However the call is placed, if B's telephone corresponding to the number tried by A 
is busy, a number of possibilities exist. Thus if B has a phone page that specifies a 
diversion number, and B has registered this service resource with the PSTN, then the 
diversion number should be automatically tried by the PSTN. However, if the diversion 
number resource has not been registered with the PSTN, a busy signal will returned 
to A. Where A has placed the call through a standard te.iphone, A must now decide 
how to proceed and A may elect either to give up or to refer again to B's phone page 
to look up the diversion number and redial using this number. If A placed the original 
call using his terminal 53 then the laner can be programmed to detect the return of a 
busy signal and then automatically look up B's diversion number and redial using this 
number. This functionality can be included in service logic downloaded from B's phone 
page and run on A's terminal. 

If A had to terminate his Internet session in order to free up the telephone line for 
voice use, then referring back to B's phone page requires a new Internet session to be 
started (in fact, this inconvenience could be avoided if B's diversion number were 
passed to A's terminal at the time the original number to be dialled for B was 
supplied). 



wo 97/22212 PCT/GB96/03055 

44 

The service resource accessed on B's phone page upon B's telephone being busy may, 
of course, be more complex than just a diversion number. In particular, user A may 
be presented with a range of options including, for example, B's fax or voice mailbox 
number, the selection of an option potentially initiating the running of appropriate 
accessing software. Another possible option would be for A to leave B a call back 
message using a form downloaded from B's phone page upon this option being chosen; 
the completed form would be posted back to server 51 and logged for B to check in 
due course. 



10 

Of course, it may arise that user A wishes to access B's phone page to find out. for 
example, B's current roaming number, but user A does not know the URI of B's Web 
site and only has B's Webtel number. A could just call B through the PSTN in which 
case the translation of B's Webtel number to roaming number would be automaticaJly 

15 effected (assuming B is still registered for this service); however, A may not wish to 
call B straight away, but just note his current roaming number. In order to solve A's 
problem, the Webtel-to-URI association tables previously described are preferably 
made accessible on the Internet at a known address (for example, ai a known Web 
site). All that A need now do is to access this Web site passing B's Webtel number: 

20 B's phone page URI will then be remmed to A who can then use it to access B's phone 
page. This process can, of course be made automatic from the point when A sends B's 
Webtel number to the association-table Web site. 



25 Internet/PSTN Call Interface 

In the Figure 14 scenario, A's access to the PSTN was through a standard telephone 
interface even though the actual form of A's telephone differed from standard by being 
integrated into A's computer terminal 53. Figure 15 illustrates a situation where A. 
after being supplied with B's current roaming number as in the Figure 14 case, calls 

30 B via a route that starts out over the Internet and then passes through a user network 
interface 80 into the PSTN. Interface 80 is arranged to convert between ISDN-tN-pe 
telephone signalling on the PSTN and corresponding signalling indications cax-ned 
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across the Imemei in IP packets: in addition, interface 80 transfers voice data from IP 
packets onto trunk 60 and vice versa. 



Thus, upon A initiating a call to B, Internet phone software 81 in A's terminal sends 
5 call initiation signalling over the Internet to interface 80, the address of which is 
already known to A's terminal. At interface 80, the signalling is converted into ISDN* - 
type signalling and passed to SSP 41. Call set up then proceeds in the normal way and 
return signalling is transferred back through interface 80, over the Internet, to the 
software 81 in A's terminal. This software passes call setup progress information to 
10 the WWW browser 73 for display to A. Upon the call becoming established, A can 
talk to B through his telephone and A's voice input is first digitised in phone hardware 
interface 83 and then insened into IP packets by software 81 to traverse the Internet 
to interface 80 (see arrow 84); voice traffic from B follows the reverse path. 

15 IN services can be provided to this call by SCP in response to a service request from 
an SSP 41. Thus, if B's phone is busy, and B is registered for call diversion, SCP 43 
on receiving a service request will access B's appropriate phone page for call diversion 
and retrieve the diversion number. If SSP 41 is not set to initiate a service request on 
B's telephone being busy, the busy indication is remmed to A's terminal where it can 

20 be handled in the manner already described with reference to Figure 14. 

In fact, interface 80 can be provided with functionality similar to an SSP to set trigger 
conditions and generate a service request to SCP 43 on these conditions being satisfied. 

25 Third-Panv Call Semp Gateway 

Figure 16 illustrates a further arrangement by which A can call B after receiving B's 
curren: roaming number. In this case, a third-parry call set-up gateway 90 is provided 
that interfaces both with the Internet 50 and with an SSP 41. Conveniently, gateway 
90 can be co-located with SCP 43 (though this is not essential). Gateway 90 has the 

30 capabi2::>- of commanding SSP 41 to set up a call between specified telephones. 
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Thus, upon A wishing to call B, a third-parT>' call setup request is sent from A's 
terminal over the Internet to the gateway 90 (see arrow 91). This setup request includes 
A's telephone number and B's current roaming number. Gateway 90 first aaempts to 
setup the call to A*s telephone (which should generally succeed) and thereafter to set 
up the call to B's identified telephone. Once the call is setup, A and B communicate 
in standard manner across the PSTN. 



If B's phone had been busy, then any of the previously described scenarios may ensue. 

10 Gateway 90 can also be arranged to make service requests to SCP 43 upon 
predetermined trigger conditions being satisfied. Thus, gateway 90 might be set to pick 
up the busy condition on B*s telephone and initiate a service request to SCP 43 for a 
diversion number. However passing the busy indication back to A's termmal via 
gateway 90 is preferred because of the flexibility it gives A regarding funher action. 

15 

As already generally discussed in relation to Figure 14, a complication arises if A only 
has Internet access via a SLIP/PPP connection over an ordinary, non-ISDN, PSTN line 
since, in this case, A's telephone line is already tied up with making Internet access 
when gateway 90 seeks to set up a call to A's telephone. The solutions discussed in 

20 respect of Figure 14 (termination of Internet session: multiplexing voice and Internet 
data on same telephone line) can also be used here. An alternative approach both for 
Figure 14 and for Figure 16 scenarios is possible if user A's terminal can handle a 
voice call as digitised voice passed over the Internet, In this case, the voice call can 
be placed through an interface 80 of the Figure 15 form, and the voice traffic and the 

25 Internet communication with the B's phone page and/or gateway 90 are both carried 
in Internet packets passed over the SLIP/PPP connection to/from A's terminal 53 but 
as logically distinct flows passed to separate applications runrung on terminal 53. 



It may be noted that the third part>' call setup request made by A's terminal to gateway 
30 90 could equally have been made by service logic held in B's phone page and executed 
by server 51 (such an arrangement would, of course, require A's telephone number to 
be passed to B's phone-page service logic and this could be arranged to occur either 
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automatically or through a form presented to user A at termmal A and then posted back 
to server 51). 



It may also be noted that the interface 80 of Figure 15 and the gateway 90 of Figure 
5 16 provide examples of service requests being passed to the service control subsystem 
by entities other than SSPs 41. 



www-based ^FreePhone'' (800 number) Services 

It is possible to implement a "FreePhone" or "800 number" type of service using a 
10 combination of the WWW and the PSTN. As will be seen from the following 
description of such a service with reference to Figure 17, a WWW/PSTN 
implementation does not necessarily rely either on transferring call charges from the 
calling to called parry or on the use of a special "800" number, two characteristics of 
standard "Freephone" schemes. The WWW/PSTN implementations do, however, 
15 possess the more general characteristic of placing an enquiring party and the party to 
whom the enquiry is directed, in telephone contact at the expense of the latter party. 

In the Figure 17 arrangement, a user D such as a large depanment store has a website 
on a server 51; for the sake of simplicity, it will be assumed that the server is under 
20 the control of user D who has direct computer access to the server over line 125. D's 
Website may, for example, contain many catalogue -like Web pages illustrating goods 
offered for sale by D. In addition, D has a freephone page 124 for handling enquiries 
placed on a freephone basis; the URL of this page is associated with a "freephone" 
graphical button 122 placed on each of the Website catalogue pages. 

25 

Suppose user A at terminal 53 is browsing D's Website, looking at the catalogue pages 
(arrow 121':. If A sees an item of interest and wishes to make an enquiry to D about 
this item, then A can activate at terminal 53 the graphical freephone bunon 122 
associated ^-ixh the catalogue page concerned. This activation causes code embedded 
30 in the catalogue page currently loaded in A's terminal to prompt the user to enter their 
telephone — rmbpr and, optionally, their name, after which an HTTP request is sent to 
D's freepfaD:>e page using the POST method and enclosing the entered data (arrow 
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123). D's freephone page on receiving this request executes service logic to enter a 
new enquiry (including A's name and telephone number) in an enquiry queue 127 
maintained in an enquiry control system 126. In the present example, the enquir>* 
control system is connected to the server 51 via line 125, externally of the Internet; 
5 however, it would also be possible to have server 51 communicate with the enquiry 
control system through the Internet and, indeed, this may be the most practical - 
arrangement where D's Website is on an ISP server rather than on a server controlled 
by D. In fact, the code run in A's terminal upon activation of the freephone graphical 
button 122 could be arranged to directly forward the enquiry request to the enquiry 
10 control system over the Internet rather than passing it back through the server 51. 

The enquiry control system 126 manages enquiries passed to it to ensure that they are 
dealt with in an ordered manner. The system 126 on receiving a new enquiry 
preferably estimates approximately how long it will be before the enquiry is dealt with, 
15 this estimation being based on the number of currently queued enquiries and the 
average time taken to handle an enquiry. This estimation of waiting time is passed back 
via server 51 to user A in the response to the POST request message. 



The enquiry control system 126 looks after the distribution of enquiries to a number 
20 of agents each of which is equipped with a telephone 40 and a display 129. A's 
enquiry will be dealt with as soon as it reaches the head of the queue 127 and there is 
an agent detected as available to handle the enquiry (thus, for example, the system may 
be arranged to detect when an agent's telephone goes on hook). When these conditions 
are met, a distribution and setup control unit 128 lakes A's enquiry and displays A's 
25 name and telephone number on the display 129 of the available agent (for clarity, 
herein referenced as agent D'); if user D keeps a database on D's past customers or 
credit rating data, then unit 128 will also look for and display any such further 
information known about A. At the same time, unit 128 makes a third-parry call semp 
request (arrow 130) over the Internet to gateway 90 asking for a call to be set up 
30 between the telephone of the available agent and the telephone of user A, both 
telephones being identified by their respective numbers. If both D' and A pick up the 
calU the enquir>' then proceeds, the cost of the call being paid for by D as i: :s D that 
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originated the call over the PSTN. If, for whatever reason, the call remains incomplete 
(for example, unanswered by A) for a predetermined timeout period, then unit 128 can 
be arranged to automatically pass on to the next enquiry at the head of the queue 127. 



5 It would, of course, be possible to dispense with having the unit 128 request call semp 
through gateway 90 and either have the agent D' dial A's number manually or have 
unit 126 initiate auto-dialling for D* telephone (agent D* having, for example, a 
computer-integrated telephone similar to that of A's in Figure 14). The advantageof 
these approaches is that the existing PSTN could be used without adaption and without 

10 any service installation, in implementing the WWW-based freephone service. 



As discussed in relation to Figures 11 and 13, a complication arises in placing a call 
to A if A only has Internet access via a SLIP/PPP connection over an ordinary, non- 
ISDN, PSTN line since, in this case, A's telephone line is already tied up with making 

15 Internet access when user D tries to set up a call to A*s telephone. The solutions 
discussed in respect of Figures 1 1 and 13 can also be used here (termination of Internet 
session; multiplexing voice and Internet data on same telephone line; and placing the 

call over the Internet to A-s terminal). With respect to the solution -based on 

termination of the Internet session, such termination could be delayed until A's enquiry 

20 was about to be dealt with; however, to do this, it would be necessary to provide 
feedback from the control system 126 over the Internet to A*s terminal 53 and to 
associate this feedback with code for bringing about Internet-session termination. One 
way to achieve this would be to have the response message sent by server 5 1 in reply 
to the original POST request message from A, include a correlation code; any 

25 subsequent feedback from system 126 passed to A would also include this code (server 
A having also passed the code to control system 126) thereby allowing A's terminal to 
correctly identif\' this feedback. In fact, the same mechanism could be used to provide 
user A with updates on how much longer user A is likely to be waiting to be called 
back, this mechanism being usable independently of whether or not there was a conflict 

30 problem for use of A's telephone line. 
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Where user A only has a telephone 40 and no terminal 53, it is still possible to utilise 
the basic structure of Figure 17 to provide a freephone service for user A without 
resorting to the complexity of call charge transfer. More particularly, A would dial a 
special number for user D's freephone service (typically an 800 number), and the SSP 
5 41 would recognise this special number in standard manner and make a service request 
to SCP 43 including both this special number and A*s number. SCP 43 would then 
ascertain D's freephone-page URL by doing a number-to-LTRL translation and access 
D*s freephone page using a POST-method HTTP request similar to request 123. Once 
this request had been registered as an enquiry by D's freephone page 124, the lattter 
10 could send a response to SCP 43 asking it to play an announcement such as "Your 
freephone enquiry has been registered; please hang up and you will be contacted 
shortly". This announcement could be played to A by an IP in standard manner. A 
would then hang up and be ready to receive a call from D. 

15 A significant advantage of the above freephone schemes using WWW, is that user D 
is not running up charges for use of the PSTN during periods when an enquiry is 
enqueued, waiting to be handled. 

Variants 

20 Many variants are, of course, possible to the above-described arrangements and a 
number of these variants are described below. 

Distributed Processing Environment. As is illustrated in Figure 18, the SCP 43 may 
access the HTTP servers 51 through a distributed processing environment, DPE 98, 
25 at least logically separate from the Internet. Preferably in this case the servers 51 are 
controlled by PSTN operators and are thus restricted in number. 

Service Resources on DNS- Type Ser-vers. In the foregoing examples, the service 
resource items have been been placed on servers 51 connected to the Internet and a 
30 desired service resource has then been accessed over the Internet by the service control 
subsystem of the PSTN, and/or by Internet users, through the use of an URI derived 
from a resource code that identities the the desired service resource item. In a 
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preferred arrangement for deriving the URI from a resource code in the form of a 
telephone number, all or part of the telephone number concerned was parsed into 
domain name form and then resolved into an URI using a DNS-type distributed 
database system that, indeed, could be integrated into the DNS itself (see Figures 11 
5 and 12, and related description). In fact, it would be possible to place service resource 
items directly in Registration Records held by a DNS-type distributed database system 
so that instead of the parsed telephone number being resolved to an URI which is then 
used to access the required resource, the parsed telephone number is directly resolved 
to the required service resource item. The mechanism employed in this process is 
10 exactly as already described for resolving a parsed telephone number into an URI. The 
DNS-type distributed database system used for this would preferably be one accessible 
over the Internet or the DNS itself so as to provide access to the service resource items 
for Internet users as well as for the service control subsystem of the PSTN (in the same 
manner as described above with reference to Figure 18, the DNS-type servers holding 

15 the service resource items may be accessible to the service control subsystem by a 
network other than the Internet). Whilst the placing of service resource items in RRs 
held on DNS-type servers may not be suitable for all types of service resource items, 
it is suitable for items such as telephone numbers that do not change frequently. Thus, 
a suitable usage is to provide number portability; in this case, a dialled personal 

20 number triggers a lookup in the DNS-type system with all or part of the personal 
number being first parsed and then applied to the DNS type system to return a current 
number for call routing. All dialled numbers could be treated as personal numbers or 
simply a subset of such numbers, this subset comprising numbers that are readily 
identifiable as personad numbers by, for example, local lookup at an SSP or the 

25 presence of a predetermined leading digit string. The general concept of parsing a 
telephoTke number (or similar number) in whole or in part to form a domain name for 
resoiirion in a DNS-type distributed database system can be used for the retrieval of 
other iienis of information besides URIs and service resource items. 

30 Feedback Mechanisms. In discussing the WWW-based freephone arrangement of 
Figure 1". it was mentioned that user A could be supplied with feedback on the likely 
leng± c: ^-aidng time before A would be called back. This is one example of using 
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the Imemet to provide a feedback path for a potential or acmai teiephcne user. Another 
example was provided in relation to Figure 16 where the progress of call setup was 
reponed back by the call setup gateway to user A's lerminai. In fact, generally where 
a user is known to be using a terminal actively on the Internet the opponunity arises 
5 to provide the user with feedback on the progress of call semp through the telephone 
system. In oreder to do this, it is of course necessary to ensure that the feedback' can 
be passed to the appropriate application running on terminal A and this will generally 
require the application to have made appropriate linking information available. As well 
as call setup progress information, other information can also be fedback for example 
10 during a call holding period. Thus, for example, a special sePr^er can be provided on 
the Internet holding multimedia clips or even videos that could be output to user A 
during a call holding period. 



In the described arrangmenis, the servers 51 have held service resource items 
15 concerned primarily with call semp control. It may be noted that in a somewhat 
different application, Internet servers could be arranged to hold data that could be 
accessed from the telephone system in response to a user-initiated teiephcne request and 
returned to that telephone user. Such a service would -^^ provided, for example, in 
response to an SSP triggering a service request upon ; articular telephone number 
20 being input, the service request prompting an SCP to cause an intelligent peripheral to 
access a panicular Internet server (not necessarily an HTTP server) and retrieve the 
required data for return to the calling party. The intelligent peripheral may include a 
text-to-voice convener for replaying the data vocally to the user. 



25 One further feedback process is also worthy of note, in this case in relation to service 
resource items themselves. By way of example, a telephone user G may subscribe to 
a service by which calls passed through to G's telephone are to be separated by a 
minimum of X minutes, X being user settable. To implen^ent this ser/ice, G has a 
phone page on a server 51 that includes a ''busy" stams indication. Upon termination 

30 of a successful call to G, G's local SSP triggers the sending of a message by the 
associated SCP over the Internet to G's phone page. This message causes G's busy 
indication to be set to indicate that G is busy; the message also starts a timer which 
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times out after a period X and causes the busy status indication to be reset. A call 
attempt to G will either be rejected at G's SSP because G's line is genuinely busy or 
will trigger the SSP to enquire via the SCP whether G's phone-page busy status 
indication is set. If the busy status indication is set (which it will be during the period 
X following termination of a successful call) the call attempt is rejected whereas if the 
busy status indication is in its reset condition, the call attempt is allowed to proceed 
By placing the busy status indication mechanism on G's phone page, it is possible to 
arrange for G to be able to easily change the value of X. 



10 More General Variants. Whilst the service control subsystem of the PSTN has been 
embodied as an SCP in the foregoing examples, it will be appreciated that the 
funcrionality of the service control subsystem could be provided as part of an SSP or 
in an associated adjunct. Furthermore, the triggering of service requests can be effected 
by equipment other than SSPs, for example by intercept boxes inserted in the SS7 

15 signalling links. 



It will be appreciated that the term "Internet" is to be understood to include not only 
the current specification of the TCP/IP protocols used for the Internet and the current 
addressing scheme, but also evolutions of these features such as may be needed to deal 
20 with isochrorious media. Furthermore, references to the WWW and the HTTP protocol 
should ecfoaDy be understood to encompass their evolved descendants. 

The present invention can also be applied to telephone systems other than just PSTNs, 
for example to PLMNs and other mobile networks, and to private systems using 
25 PABXs. In tnis latter case, a LAN or campus- wide computer network serving generally 
the saine inrsmal users as the PABX, will take the role of the Internet in the described 
e m bodimerirs . 

Funhermcre, the present invention has application where any switched 
30 taleco— imiimication system (for example, a broadband ATM system) requires service 
contrcl and z computer network can be used for the delivery of service resources to the 
ser/ice cca^ol subsystem of the telecommunication system. 
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CLAIMS 

1. A method of accessing sen'ice resource items for use in respect of setting up bearer 
channels through a switched telecommunications system, said method including the 

5 steps of: 

(a) - provisioning at least one server connected to a computer network with a - 

plurality of service resource items that are thereafter locatable on said computer 
network by corresponding known URIs, said computer network being logically 
distinct from the telecommunications system, and said service resource items 
10 relating to setup control for bearer channels through said telecommunications 

system with each said service resource item being associated with a respective 
predetermined code, said predetermined codes being distinct from said URIs 
and identifying end-point entities for said bearer channels; 

(b) — providing a mapping between ^^ach said predetermined code and the said known 
15 URI of the service resource item associated with that predetermined code; and 

(c) — utilising a said predetermined code to access a corresponding said service 

resource item by using said mapping to determine the URI corresponding to that 
resource item and then using this URI to access r!ie service resource item over 
said computer network. 

20 

2. A method according to claim U wherein at least some of said URIs are derivable 
from their corresponding said predetermined codes by manipulation according to a 
function specified by said mapping. 

25 3, A method according to claim 1, wherein at least some of said URIs are derivable 
from their corresponding said predetermined codes by look up in an association table 
associating said predetermined codes and URIs according to said mapping. 

4, A method according to claim 3, wherein said association table is held on at least 
30 one database server connected to said computer network, step (c) involving accessing 
said database server over the computer network co determine the said URI 
corresponding to the said predetermined code. 
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5, A method according to claim 4, wherein said at least one database server is 
provided by a DNS-type distributed database system in which said URIs are held in 
records associated with respective names, herein referred to as domain names, by 
which the records can be retrieved, step (c) involving translating said predetermined 

5 code into a corresponding said domain name and using this domain name to retrieve 
the URI of the required service resource item from said DNS-type distributed database- 
system. 

6, A method according to claim 1, wherein at least two said service resource items 
10 are located at the same URI, the said predetermined codes of these service resource 

items including respective relative-resource-identifier values that are used at the servxr 
holding the service resource items to identify the required resource item amongst the 
service resource items at the same URI. 

15 7, A method according to any one of the preceding claims, wherein said switched 
telecommunications system is a telephone system and said predetermined codes 
comprise numbers from at least one of the following categories: 

the telephone number of the calling party; 

the telephone number of the called party. 
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8. A method according to claim 1, wherein said switched teleconmiunication system 
is a telephone system, at least some of said predetermined codes being called-part\' 
telephone numbers and serving to retrive service resource items that are the current 
telephone numbers of the called parties. 

9, A method according to any one of the preceding claims, wherein at least one said 
service resource items is service logic which is executed by the corresponding ser%'er 
upon being accessed with the result of this execution being remmed to the accessing 
entit\' for use in bearer-channel setup control. 
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10, A method according to any one of the preceding claims, wherein at least one said 
service resource items is downloadable service data which upon being accessed is 
downloaded to the accessing entity for use thereby in bearer-channel setup control. 

5 11. A method according to any one of the preceding claims, wherein at least one said 
service resource items is downloadable service logic which upon being accessed is 
downloaded to the accessing entity for execution in bearer-channel setup control. 

12. A method according to claim 1, wherein said computer network is generally 
10 accessible to users of the telecommunications system. 

13. A method according to any one of the preceding claims, wherein said computer 
network is the Internet. 

15 14, A method according to any one of the preceding claims, wherein said switched 
telecommunication network is a PSTN. 

15. A method according to any one of claims 1 to 13, wherein said telecommunication 
system is a private system including a PABX with whic:; said service control system 

20 is associated, and wherein said computer network is a LAN. 

16. A method according to any one of the preceding claims, wherein said URIs are 
URLs and/or URNs, and said server is an HTTP server. 
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